# PATENT ABSTRACTS OF JAPAN

(11)Publication number:

2002-358492

(43) Date of publication of application: 13.12.2002

(51)Int.CI.

G06K 19/07 G06F 12/00

(21)Application number: 2001-164980

(71)Applicant: DAINIPPON PRINTING CO LTD

(22)Date of filing:

31.05.2001

(72)Inventor: HAGINIWA TAKASHI

# (54) IC CARD AND ITS ARTIFICIAL PARALLEL PROCESSING PROGRAM

(57)Abstract:

PROBLEM TO BE SOLVED: To provide an IC card whose processing speed can be improved and its artificial parallel

processing program.

SOLUTION: The IC card 1, equipped with a CPU 20 which sequentially processes a plurality of instructions inputted from an external terminal 2, is equipped with an performance environment preparing means 21 which performs garbage collection in a reception wait time before the reception of a next instruction after a response to one instruction is made.



# **LEGAL STATUS**

[Date of request for examination]

[Date of sending the examiner's decision of rejection]

[Kind of final disposal of application other than the examiner's decision of rejection or application converted registration]

[Date of final disposal for application]

[Patent number]

[Date of registration]

[Number of appeal against examiner's decision of rejection]

[Date of requesting appeal against examiner's decision of rejection]

[Date of extinction of right]

Copyright (C): 1998,2003 Japan Patent Office

# (19)日本国特許庁 (JP) (12) 公開特許公報 (A)

(11)特許出願公開番号 特開2002-358492 (P2002-358492A)

(43)公開日 平成14年12月13日(2002.12.13)

| (51) Int.Cl.7 | 識別記号 | FΙ         | ;   | テーマコード( <del>参考</del> ) |
|---------------|------|------------|-----|-------------------------|
| G06K 19/07    |      | G06F 12/00 | 591 | 5B035                   |
| G06F 12/00    | 591  | G06K 19/00 | N   | 5B060                   |

# 審査請求 未請求 請求項の数6 OL (全 7 頁)

| (21)出願番号 | 特願2001-164980(P2001-164980) | (71)出顧人 000002897                  |
|----------|-----------------------------|------------------------------------|
|          |                             | 大日本印刷株式会社                          |
| (22)出顧日  | 平成13年5月31日(2001.5.31)       | 東京都新宿区市谷加賀町一丁目1番1号                 |
|          |                             | (72)発明者 获庭 崇                       |
|          |                             | 東京都新宿区市谷加賀町一丁目1番1号                 |
|          |                             | 大日本印刷株式会社内                         |
|          |                             | (74)代理人 100092576                  |
|          |                             | 弁理士 鎌田 久男                          |
|          |                             | Fターム(参考) 5B035 AA02 BB09 CA11 CA29 |
|          |                             | 5B060 AA10 MM09                    |
|          |                             |                                    |
|          |                             |                                    |
|          |                             | ·                                  |
|          |                             |                                    |

# (54) 【発明の名称】 ICカード及びその擬似並列処理プログラム

# (57)【要約】

【課題】 処理速度の向上を図ることができるICカー ド及びその擬似並列処理プログラムを提供する。

【解決手段】 外部の端末2から入力された複数の命令 を逐次処理するCPU20を備えるICカード1であっ て、一の命令に対する応答の送信後、次の命令の受信前 である受信待ち時間に、ガーベイジコレクションを行う 実行環境整備手段21を備える。



#### 【特許請求の範囲】

【請求項1】 一の外部装置から入力された複数の命令情報を逐次処理するCPUを備えるICカードであって、

一の命令情報に対する応答情報の送信後、次の命令情報の受信前である受信待ち時間に、命令情報を処理する実行環境を整備する実行環境整備処理を行う実行環境整備手段を備えること、を特徴とするICカード。

【請求項2】 請求項1に記載のICカードにおいて、前記CPUが実行可能な1又は2以上のアプリケーションプログラムが格納される書き換え可能な不揮発性メモリを備え、

前記実行環境整備処理手段は、前記不揮発性メモリにおいて、空き領域の確保及び/又は解放を行うメモリ管理 処理を行うこと、を特徴とする I Cカード。

【請求項3】 請求項1又は請求項2に記載のICカードにおいて、

前記実行環境整備処理の実行中に前記次の命令情報を受信した場合に、前記環境整備処理の実行を中断し、前記次の命令情報の処理を割り込ませる割込手段を備えること、を特徴とするICカード。

【請求項4】 外部から入力した複数の命令情報の処理をCPUに実行させるためのICカードに格納される擬似並列処理プログラムであって、

一の命令情報に対する応答情報の送信後、次の命令情報の受信前である受信待ち時間に、命令情報を処理する実行環境を整備する実行環境整備処理を行う実行環境整備手順を備えること、を特徴とする擬似並列処理プログラム。

【請求項5】 請求項4に記載の擬似並列処理プログラムにおいて、

前記実行環境整備手順は、空き領域の確保及び/又は解放を行うこと、を特徴とする擬似並列処理プログラム。

【請求項6】 請求項4又は請求項5に記載の擬似並列 処理プログラムにおいて、

前記命令情報を受信した場合に、前記実行環境整備手順 を中断させ、前記命令情報の処理を割り込ませる割込手 順を備えること、を特徴とする擬似並列処理プログラ ム。

## 【発明の詳細な説明】

[0001]

【発明の属する技術分野】本発明は、複数のアプリケーションを搭載した I Cカード及びその擬似並列処理プログラムに関するものである。

[0002]

【従来の技術】図3は、従来のICカードを示すブロック図である。図3に示すように、従来のICカード1-2は、I/Oインターフェイス10-2、CPU20-2、ROM40-2、RAM30、EEPROM50等を備える、接触型のICカードである。I/Oインター

フェイス 10-2は、端末 2と情報を送受信するための入出力回路であり、Vcc、RST、CLK、I/O、GND等、複数の接点を備えている。ICカード1-2を端末 2に挿入すると、端末 2の接点がこれらの接点と接続され、電気信号の授受が行われる。各接点には、それぞれ異なる電気信号が割り付けられている。例えば、Vccは、CPU 20-2が動作するために必要な電源電圧の供給を受けるための接点であり、I/Oは、CPU 20-2が端末 2と通信を行うための接点(シリアルポート)である。

【0003】CPU20-2は、このICカード1-2を統括制御する中央処理装置であり、I/Oインターフェイス10-2及びROM40-2、RAM30、EEPROM50等のメモリ等が接続されている。CPU20-2は、I/Oインターフェイス10-2を介して、端末2から命令を受け、ROM40-2又はEEPROM50に格納されたプログラムに基づいて、RAM30又はEEPROM50の作業領域を使用し、逐次処理する。

【0004】RAM30は、揮発性メモリであり、CP U20-2が処理を行う作業領域として使用される。R OM40-2は、不揮発性の読み出し専用メモリであっ て、ICカードの用途によらず汎用的に使用できるプロ グラムであるオペレーティングシステム(以下、OSと する)を格納している。OSは、ICカード1-2のハ ードウェア及びソフトウェアを有効に利用するために総 合管理を行うプログラムであり、CPU20-2に端末 2からの命令に対応した処理を行わせる。EEPROM 50は、随時書き換え可能なメモリであり、複数のアプ リケーションプログラム、ICカードユーザに関する個 人情報等のデータ等を格納している。また、EEPRO M50は、OSやアプリケーションの作業領域として使 用されることもある。アプリケーションプログラムは、 OSの管理下において、ICカードの各種用途固有の処 理を行うプログラムである。

【0005】端末2は、リーダライタ等を備え、挿入されたICカード1に、命令、電源、クロック等を供給する。端末2は、ICカード1に命令を与え、応答を受けとる情報の授受による処理単位を繰り返すことにより、認証等を行う。

【0006】図4は、従来のICカード1-2に格納されているOSの処理を示すフローチャートである。S500において、ICカード1-2が端末2に挿入され、接続される。ICカード1-2は、電源供給及び命令を端末2から受けることにより、リセット(活性化)され、処理を開始する。S501において、OSは、自己診断処理を実行し、OS自身が正常であるかをチェックする。OSは、通信条件等を含む初期応答情報(S504TRとする。)をレスポンスとして送出する(S502)。ATRを送出後、端末2から送信される命令の受

信待ちの状態となり、省電力モードに入る(S50 3)。S504において、OSは、端末2からの命令を 受信し、命令を解析する(S505)。

【〇〇〇7】S506において、OSは、自己が処理する命令であるか否かを判定し、OSへの命令である場合には、処理を行い、命令を実行する(S507)。アプリケーションプログラムへの命令である場合には、どのアプリケーションプログラムに対するものであるかを判断し、命令を伝達する(S508)。S509において、OSから命令の伝達を受けたアプリケーションプ グラムは、OSから伝達された命令を解釈・実行し、その結果をOSに返す。S510において、OSは自身の処理結果またはアプリケーションプログラムによる処理結果を端末2へ送出し、受信待ちの状態となり(S503)、同様の処理を繰り返す。

#### [0008]

【発明が解決しようとする課題】しかし、すべての命令をこのように直列的に処理するのでは、近年のICカードの多機能化に伴い処理速度(受信ー命令実行ー送信)が落ちてしまうという問題があった。一方、通常のコンピュータのCPUが有する並列処理機能(マルチプロセス機能)は、複数の処理を並行して行うことにより、処理速度の向上を図ることが可能であるが、ICカードにおいてはCPUの限界から、マルチプロセス機能の搭載は難しいという問題があった。

【0009】本発明の課題は、処理速度の向上を図ることができるICカード及びその擬似並列処理プログラムを提供することである。

#### [0010]

【課題を解決するための手段】本発明は、以下のような解決手段により、前記課題を解決する。なお、理解を容易にするために、本発明の実施形態に対応する符号を付して説明するが、これに限定されるものではない。すなわち、請求項1の発明は、一の外部装置(2)から入力された複数の命令情報を逐次処理するCPU(20)を備える1Cカード(1)であって、一の命令情報に対する応答情報の送信後、次の命令情報の受信前である受信待ち時間に、命令情報を処理する実行環境を整備する実行環境整備処理(S111からS115まで)を行う実行環境整備手段(21)を備えること、を特徴とする1Cカード(1)である。

【0011】請求項2の発明は、請求項1に記載のICカードにおいて、前記CPUが実行可能な1又は2以上のアプリケーションプログラムが格納される書き換え可能な不揮発性メモリ(50)を備え、前記実行環境整備処理手段は、前記不揮発性メモリにおいて、空き領域の確保及び/又は解放を行うメモリ管理処理を行うこと、を特徴とするICカード(1)である。

【OO12】請求項3の発明は、請求項1又は請求項2 に記載のICカードにおいて、前記実行環境整備処理の 実行中に前記次の命令情報を受信した場合に、前記環境 整備処理の実行を中断し、前記次の命令情報の処理を割 り込ませる割込手段(22)を備えること、を特徴とす るICカード(1)である。

【0013】請求項4の発明は、外部(2)から入力した複数の命令情報の処理をCPU(20)に実行させるためのICカード(1)に格納される擬似並列処理プログラムであって、一の命令情報に対する応答情報の送信後、次の命令情報の受信前である受信待ち時間に、命令情報を処理する実行環境を整備する実行環境整備処理を行う実行環境整備手順(S111からS115まで)を備えること、を特徴とする擬似並列処理プログラムである。

【0014】請求項5の発明は、請求項4に配載の擬似並列処理プログラムにおいて、前配実行環境整備手順は、空き領域の確保及び/又は解放を行うこと、を特徴とする擬似並列処理プログラムである。

【0015】請求項6の発明は、請求項4又は請求項5に記載の撥似並列処理プログラムにおいて、前記命令情報を受信した場合に、前記実行環境整備手順を中断させ、前記命令情報の処理を割り込ませる割込手順(S103、S120からS123まで)を備えること、を特徴とする擬似並列処理プログラムである。

#### [0016]

【発明の実施の形態】以下、図面等を参照しながら、本 発明の実施の形態について、更に詳しく説明する。

(実施形態)図1は、本発明によるICカードの実施形態を示すブロック図である。なお、前述した従来例と同様の機能を果たす部分には、同一の符号を付して、重複する説明を適宜省略する。図1に示すように、ICカード1は、JavaCard (サン・マイクロシステムズ社)等、インタプリタ言語の実行環境を搭載し、複数のアプリケーションプログラムを搭載している接触型のICカードである。ICカード1は、I/Oインターフェイス10、CPU20、RAM30、ROM40、EEPROM50等を備えている。

【0017】 I / Oインターフェイス10は、端末2からの命令を受信すると、割込信号をCPU20の割込手段22に送る。

【0018】CPU20は、このICカード1を統括制御する中央処理装置であり、実行環境整備手段21、割込手段22等を備えている。実行環境整備手段21は、命令の応答を端末2へ送信した後、次の命令を受信するまでの受信待ち時間に、別処理を行う。別処理は、EEPROM50の空き領域の確保及び解放を行うガーベジコレクション(以下、GCとする。)等のメモリ管環境を整備する処理である。GCとは、OSが参照されなくなったメモリ空間を発見して回収し、各アプリケーションが実行中に行うメモリの要求に対し、メモリを割り

当てる処理である。また、回収した細切れになったメモリ空間をつなげて広いメモリ空間を作り出すように処理を行ってもよい。割込手段22は、実行環境整備手段21が処理実行中にI/Oインターフェイス10から送られた割込信号を確認すると、命令の処理を割り込ませ、命令の処理後に実行環境整備手段21に処理を再開させるように制御を行う。

【〇〇19】ROM40は、不揮発性の読み出し専用メモリであって、ICカードの用途によらず汎用的に使用できるプログラムであるOSを格納している。OSにより、CPU20に実行環境整備手段21及び割込手段22等が設けられる。

【0020】図2は、本発明によるICカード1に格納されているOSの処理を示すフローチャートである。S100からS102まで、ICカード1は、従来例のS500からS502(図4参照)と同様の処理を行う。S103において、割込手段22は、I/Oインターフェイス10が命令を端末2から受信した場合に割り込み用フラグを設定する。S111において、OSは、別処理であるGCを行う必要があるか否かを判定する。十分な空き領域がEEPROM50に確保され、GCの必要がない場合には、省電力モドに切り換え、受信待ちの状態となる(S116)。GCの必要がある場合には、GC処理の進捗が把握するため、STEP(処理段階)=1、address(検索するメモリ領域の相対アドレス)=0と変数をセットする(S112)。

【0021】S113において、実行環境整備手段21 は、EEPROM50のメモリ空間を検索し、アプリケ ーションプログラムから参照されているオブジェクト (プログラムから利用するメモリの単位) にマークを付 ける。検索が進むたびにaddressを増加させる。 addressは、メモリ領域のどこまで検索を行った かを示している。検索がメモリ空間の最後まで進むと、 STEP=2、address=0に変数をセットし、 次の処理段階に入る(S114)。S115において、 実行環境整備手段21は、メモリ空間を検索し、マーク のついていないオブジェクトを解放することにより、再 度アプリケーションから利用できる状態にする。処理が 進むたびにaddressを増加させる。実行環境整備 手段21は、検索がメモリ空間の最後まで進むと、GC 処理終了を示すSTEP=3に変数をセットし、省電力 モードに入り、何も処理を行わない(S116)。S1 11~8116の間に、1/0インターフェイス10 は、端末2から命令を受信し、割込信号を割込手段22 に送る。割込信号を受けた割込手段22は、受信した命 令の処理を割込ませるための制御を行う(S120か) ら)。

【0022】S121において、割込手段22は、GC 処理で使用していたレジスタやプログラムカウンタ等の 変数を一時退避させ、端末2からの命令をI/Oインターフェイス10から受信する(S122)。S123において、割込手段22は、処理の進捗状況を保存し、次回のGC処理に備えるため、STEP及びAdressをメモリに記憶する。割込手段22は、必要なら切りのよいところまで実行環境整備手段21に処理を継続させる。

【0023】S124からS129まで、OSは、S505からS510(図4参照)と同様の処理を行い、S103の受信待ち割込み設定に戻り、同様の処理を繰り返す。

【0024】このように、本実施形態によれば、ICカード1は、従来のICカード1ー2における受信待ち時間(図4、S503)を利用し、擬似的な並列処理を行うことにより、アプリケーションの処理時間に影響を与えることなく別処理を実行し、全ての処理を直列的に影響で与える場合に比べ、全体の処理速度を向上させることが可能となった。また、ICカード1は、別処理としてGC等のメモリ管理を行うことにより、命令の処理速度の向上が図れるとともに、アプリケーションプログラムの開発、作成が容易であり、格納できるアプリケーションソフトの限定が少なく、汎用性を高めることが可能となった。

【0025】(変形形態)以上説明した実施形態に限定されることなく、種々の変形や変更が可能であって、それらも本発明の均等の範囲内である。例えば、ICカード1は、端末2と非接触で通信を行う非接触型ICカード、接触・非接触兼用型ICカード、また、複数のアプリケーションを搭載した多機能ICカードであってもよい。

【OO26】ICカード1は、GSM規格で規定されている小型のPlugーin-SIM(Subscriber Identification Module:加入者識別素子)サイズのSIMカードであってもよい。移動体通信機の番号を特定すること等を目的として使用することが可能である。また、ICカード1は、ICタグであってもよい。

【OO27】ICカード1は、別処理としてGCを待ち時間に行うが、ファイルを削除し、空いた領域を詰める処理であるファイルのデフラグ処理、ウィルスチェックを含む自己診断処理等、他の実行環境整備処理を行ってもよい。また、複数の別処理から優先順位を判断し、処理を実行してもよい。

## [0028]

【発明の効果】以上詳しく説明したように、本発明によれば、受信待ち時間に実行環境整備処理を行うことで、 直列的に処理を行う場合に比べ、処理速度を向上させる ことが可能となった。また、メモリ管理を行うことによ り、命令情報の処理速度の向上が図れるとともに、汎用 性を高めることが可能となった。更に、命令情報の処理 を割込により行うことにより、命令情報の処理速度を変 えることなく、実行環境整備処理を行うことが可能であ り、効率的に命令情報及び実行環境整備を行うことが可 能となった。

# 【図面の簡単な説明】

【図1】本発明によるICカードの実施形態を示すブロック図である。

【図2】本発明によるICカードに格納されているOSの処理を示すフローチャートである。

【図3】従来の I Cカードを示すブロック図である。

【図4】従来の I Cカードに格納されているOSの処理

を示すフローチャートである。

### 【符号の説明】

1, 1-2 1 Cカード

2 端末

10, 10-2 1/0インターフェイス

20, 20-2 CPU

21 実行環境整備手段

22 割込手段

30 RAM

40, 40-2 ROM

50 EEPROM

【図2】





